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j^ CLAIMS 

Whatjs_£laimed is: 

1 Ah system for synchronizing data between a first system and 

2 ^second system, comprising: 

3 a first synct engine on the first system interfacing with data on the 

4 first system to provide difference information; 

5 a data store coupled to network and in communication with the first 

6 and second systems\and 

7 a second sync engine on the second system coupled to receive the 

8 difference information from the data store via the network, and interfacing 

9 with data on the second system to update said data on the second system 
10 with said difference information. 

1 2. The apparatus of claim 1 wherein the first system and second 

2 system are coupled to the\erver via a private network. 

1 3. The apparatus of claim 1 wherein the first system and second 

2 system are coupled to the serverwia an Internet connection. 

1 4. The apparatus of claim \ wherein the difference information 

2 is transmitted to the data store by the first sync engine and received from 

3 the data store from the second sync engine. 

1 5. The apparatus of claim 4 wherein the difference information 

2 is transmitted to the data store at a first point in timV and received from the 

3 data store at a second, subsequent point in time. \ 
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1 8l The apparatus of claim 1 wherein said second sync engine 

2 interfaces with said data on the second system to provide second 

3 difference\information to the data store. 

1 7. Vhe apparatus of claim 6 wherein the first sync engine 

2 couples to the oata store to retrieve the second difference information and 

3 interfaces with tnfe data on the first system to update said data on the first 

4 system with said second difference information. 

1 8. The apparatus of claim 1 further including a management 

2 server coupled to the network and in communication with the first sync 

3 engine, the second sync engine and the data store. 

1 9. The apparatus W claim 8 wherein said management server 

2 authorizes access of difference information on the data store by the first 

3 and second sync engines. \ 

1 10. The apparatus of claim 8 wherein said management server 

2 locks access to difference information on the data store during 

3 communication with the first and the second sync engines. 

1 11. The apparatus of claim 1 further including a first device, 

2 coupled to the first system via the network, providing said data to the first 

3 system. \ 

1 1 2. The apparatus of claim 1 1 wherein th\ first system is a sync 
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2 server. 

1 13. \ The apparatus of claim 11 wherein said data comprises 

2 changes to aWevious state of the data, and said difference information 

3 comprises said changes in an encoded, universal format. 

1 14. The Napparatus of claim 1 wherein said sync engine 

2 comprises: \ 

3 a data interfaces 

4 a copy of a previous state of said data; and 

5 a difference transaction generator. 

1 15. The apparatus of claim 1 wherein said data on said first 

2 system comprises application data having a plurality of application specific 

3 formats, and said difference information is provided for each of said 

4 formats in a universal format to said data store. 

1 16. The apparatus of claim 1 further including: 

2 a plurality of sync engines on a respective plurality of systems, each 

3 of said plurality of engines being coupled tb receive difference information 

4 from each of said first, second and pluralityW sync engines from the data 

5 store via the network, and each said engineyiterfacing with data on the 

6 system on which it resides to update said dataXDn said system on which it 

7 resides with said difference information, and interface with data on said 

8 system on which it resides to provide difference data information from the 

9 system on which it resides to the data store. \ 
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1 17. \ A system, comprising: 

2 a first gevice including at least a first data file and first differencing 

3 code having ah input and an output coupled to a network to receive first 

4 device data change transactions, based on said at least one data file, from 

5 and provide change transactions to, said network; 

\ 

6 a data store 'poupled to the network having at least one data 

7 structure coupled to stV^re change transactions; and 

8 a second system Vicluding at least a second data file and second 

9 differencing code having an input and an output coupled to the network to 

10 receive said first device data change transactions, and provide second 

1 1 change transactions based on said at least second data file to said data 

12 store. \ 

1 18. The apparatus of Vlaim 17 wherein the first device and 

2 second device are coupled to theydata store via an Internet connection. 

1 19. The apparatus of damn 17 wherein the first change 

2 transactions are transmitted to the data store by the first device at a first 

3 point in time and received from the data^store by the second device at a 

4 second, subsequent point in time. \ 

1 20. The apparatus of claim 1 7 wherein the first differencing code 

2 receives second change transactions from the crata store to and interfaces 

3 with at least the first data file on to update said data with said second 

4 change transactions. \ 

1 21 . The apparatus of claim 17 further including a management 
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2 server coupled to the network and in communication with the first sync 

3 engine, the second sync engine and the data store. 

1 22. The apparatus of claim 1 7 wherein said management server 

2 authorizes accessNpf difference information on the data store by the first 

3 and second differencing code. 

1 23. The apparatus of claim 1 7 wherein the first device is a sync 

2 server. \ 

1 24. The apparatus of claim 17 wherein said differencing code 

2 comprises: \ 

3 an application object; \ 

4 an application object storey and 

5 a delta engine. \ 

1 25. A method for synchronizing at least a first and a second 

2 resident on a first and a second systems, respectively, coupled to the 

3 Internet, respectively, comprising: \ 

4 determining difference data resulting from changes to the first file 

5 on the first system; \ 

6 transmitting the difference data to a server via the Internet; 

7 querying the server from a second syfetem to determine whether 

8 difference data exists for files on the second system; 

9 retrieving the difference data to the second system; and 

10 updating the second file on the second system with the difference 
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11 data. 

1 26.\ The method of claim 25 wherein said step of determining 

2 comprises: \ 

3 comparing a current instance of the first file to a stored instance of 

4 the first file; and\ 

5 generating said difference data. 

1 27. The method of claim 25 wherein said step of querying 

2 comprises: \ 

3 coupling to a management server which provides information on a 

4 state of said difference data for files on the first system and the second 

5 system. \ 

1 28. The method of claim 25 wherein said step of retrieving 

2 comprises: \ 

3 coupling to the managemenryserver; 

4 receiving authorization from the management server to retrieve the 

5 difference data; \ 

6 transmitting a request to the server for the difference data; and 

7 receiving the difference data in response to the request. 

1 29. The method of claim 28 wherern the management server 

2 locks the server from receiving further requests for the difference data 

3 during said retrieving step. \ 
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1 30. VThe method of claim 25 wherein said step of updating 

2 comprises: \ 

3 applying the difference data to a stored instance of the second file 

4 on the second s^)stem. 

1 31. An Internet synchronization system, comprising: 

2 a storage server having an Internet connection; 

3 a first device coupled to the Internet and including a device sync 

4 engine; and \ 

5 a second device coupled to the Internet and including a second 

6 device sync engine. \ 

1 32. The Internet synchronization system of claim 31 further 

2 including: \ 

3 a management server. \ 

1 33. The Internet synchroni^ion^s^m of claim 32 wherein the 

2 storage server and the management seKver are provided in a data center. 

1 34. The Internet synchronization system of claim 31 wherein 

2 communications between the first device, the second device and the 

3 storage server are encoded and compressed. 

1 35. The Internet synchronization system of claim 31 wherein data 

2 transfer between the first device, the second device and the storage server 

3 comprises difference transactions. \ 
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1 36. The Internet synchronization system of claim 31 wherein 

2 each device includes applications having data in an application specific 

3 format, and wherein communication between the first device, the second 

4 device and the storage server include changes to said data in an 

5 application independent formatX 

1 37. The Internet synchronization system of claim 31 wherein 

2 each device sync engine comprises:\ 

3 an application object; \ 

4 an application object store; and \ 

5 a delta engine. \ 
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